<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <script src="lib/react.development.js"></script>
    <script src="lib/react-dom.development.js"></script>
    <script src="lib/babel.min.js"></script>
</head>
<body>
<div id="root"></div>
</body>
<script type="text/babel">
    // 1- 如何设置状态
    // 2- 如何修改   this.setState
    // 注意：
    //   1- 如果更新的状态是一个引用类型，只有更改了其引用地址，那么视图才会更新
    const root = ReactDOM.createRoot(document.querySelector("#root"));
    class App extends React.Component{
        state = {
            num:1,
            arr:[1,2,3,4]
        }
        render(){
            return (
                <>
                    <button onClick={()=>{
                        // 以下程序视图不会更新数组
                        // this.state.arr.push(this.state.arr.length+1)
                        // this.setState({
                        //     num:this.state.num+1,
                        //     arr:this.state.arr
                        // })

                        // 需要更改数组的引用地址，更新视图
                        this.setState({
                            num:this.state.num + 1,
                            arr:[
                                ...this.state.arr,
                                this.state.arr.length+1
                            ]
                        })
                    }}>{this.state.num}</button>
                    {
                        this.state.arr
                    }
                </>

            )
        }
    }
    root.render((
        <App></App>
    ))
</script>
</html>